草庐IT

Java String.replaceAll 正则表达式

全部标签

ruby - 将字符串转换为正则表达式 ruby

我需要将像“/[\w\s]+/”这样的字符串转换为正则表达式。"/[\w\s]+/"=>/[\w\s]+/我尝试使用不同的Regexp方法,例如:Regexp.new("/[\w\s]+/")=>/\/[w]+\//,类似Regexp.compile和Regexp.escape。但它们都没有像我预期的那样返回。此外,我还尝试删除反斜杠:Regexp.new("[\w\s]+")=>/[w]+/但运气不好。然后我试着简单一点:str="[\w\s]+"=>"[w]+"它逃脱了。现在字符串如何保持原样并转换为正则表达式对象? 最佳答案

Ruby 用捕获的正则表达式模式替换字符串

我在将它翻译成Ruby时遇到了问题。这是一段JavaScript,它完全符合我的要求:functionget_code(str){returnstr.replace(/^(Z_.*):.*/,"$1")​​​​​​​​​​​​​​​​​​​​​​​​​​​;}我试过了gsub,sub,和replace但似乎没有一个能达到我的预期。以下是我尝试过的示例:"Z_sdsd:sdsd".gsub(/^(Z_.*):.*/){|capture|capture}"Z_sdsd:sdsd".gsub(/^(Z_.*):.*/,"$1")"Z_sdsd:sdsd".gsub(/^(Z_.*):.*/,

Ruby 正则表达式组匹配,在 1 行上分配变量

我目前正在尝试将一个字符串转换为多个变量。示例字符串:ryan_string="RyanOnRails:Thisisatest"我已将其与此正则表达式匹配,分为3组:ryan_group=ryan_string.scan(/(^.*)(:)(.*)/i)现在要访问每个组,我必须执行如下操作:ryan_group[0][0](firstgroup)RyanOnRailsryan_group[0][1](secondgroup):ryan_group[0][2](thirdgroup)Thisisatest这看起来很荒谬,感觉我做错了什么。我希望能够做这样的事情:g1,g2,g3=ryan

ruby - 使用正则表达式从 Ruby 中的字符串中提取子字符串

如何从Ruby中的字符串中提取子字符串?例子:String1=""我想提取substring来自String1(即最后一次出现的和>中的所有内容)。 最佳答案 ""[/.*]*)/,1]=>"substring"不需要使用scan,如果我们只需要一个结果。当我们有Ruby的String[regexp,#]时,不需要使用Python的match。参见:http://ruby-doc.org/core/String.html#method-i-5B-5D注意:str[regexp,capture]→new_strornil

ruby-on-rails - Ruby %r{ } 表达式

模型中有一个字段validates:image_file_name,:format=>{:with=>%r{\.(gif|jpg|jpeg|png)$}i这对我来说看起来很奇怪。我知道这是一个正则表达式。但我想:了解它的确切含义。%r{value}是否等于/value/?能够用普通的Ruby正则表达式运算符/someregex/或=~替换它。这可能吗? 最佳答案 %r{}等同于/.../表示法,但允许您在正则表达式中包含“/”而无需转义它们:%r{/home/user}相当于:/\/home\/user/为了易读性,这只是一种语法商

ruby - Ruby正则表达式中\A\z和^$的区别

在我阅读的文档中:Use\Aand\ztomatchthestartandendofthestring,^and$matchthestart/endofaline.我将应用正则表达式来检查用户提交的用户名(或电子邮件是否相同)。我应该在模型中将哪个表达式与validates_format_of一起使用?我无法理解其中的区别:我一直使用^和$... 最佳答案 如果您依赖正则表达式进行验证,您总是希望使用\A和\z.^和$只会匹配到换行符,这意味着他们可以使用像me@example.com\ndangerous_stuff();这样的电

ruby - 如何在 Ruby 中匹配所有出现的正则表达式

有没有一种快速的方法可以在Ruby中找到每个正则表达式的匹配项?我查看了RubySTL中的Regex对象并在Google上搜索无果。 最佳答案 使用scan应该做的伎俩:string.scan(/regex/) 关于ruby-如何在Ruby中匹配所有出现的正则表达式,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/80357/

javascript - 正则表达式中的 $ 与行尾不匹配

我对以下正则表达式有疑问:vars="http://www.google.com/dir/file\r\nhello"varre=newRegExp("http://([^/]+).*/([^/\r\n]+)$");vararr=re.exec(s);alert(arr[2]);在上面,我希望arr[2](即捕获组2)是"file",与最后一个匹配应用贪心后第一行中的4个字符。*,由于/中的回溯模式,然后通过$锚定在行尾。事实上,arr[]为空,这意味着模式甚至不匹配。我可以稍微改变它,使其完全符合我的意图:vars="http://www.google.com/dir/file\r\

javascript - 正则表达式匹配的内容

我一直在尝试将以下内容从Python转换为node.js。这是一个使用正则表达式检查IP地址是公共(public)地址还是私有(private)地址的简单程序:importredefis_private_ip(ip):"""Returns`True`ifthe`ip`parameterisaprivatenetworkaddress."""c=re.compile('(^127\.0\.0\.1)|(^10\.)|(^172\.1[6-9]\.)|(^172\.2[0-9]\.)|(^172\.3[0-1]\.)|(^192\.168\.)')ifc.match(ip):returnT

javascript - 正则表达式:匹配 DNA 序列的排列

如何制作正则表达式来评估以下字符串?TGATGCCGTCCCCTCAACTTGAGTGCTCCTAATGCGTTGC并提取模式CTCCT。模式必须是3个C和2个T,顺序不限。我试过/[C|T]{5}/但它匹配CCCCT和TCCCC提前致谢。 最佳答案 计算“CTCCT”的所有排列并将它们连接到正则表达式:CCCTT|CCTCT|CCTTC|CTCCT|CTCTC|CTTCC|TCCCT|TCCTC|TCTCC|TTCCC这个模式可以是optimized:C(?:C(?:T(?:CT|TC)|CTT)|T(?:C(?:CT|TC)|T